草庐IT

SQL EXISTS 运算符

全部标签

c++ - 关于 C++ 中 sizeof 运算符的强大功能

我正在阅读现代C++设计。下面的描述中提到了sizeofoperator。以下段落从泛型编程的角度进行解释。Thereisasurprisingamountofpowerinsizeof:Youcanapplysizeoftoanyexpression,nomatterhowcomplex,andsizeofreturnsitssizewithoutactuallyevaluatingthatexpressionatruntime.Thismeansthatsizeofisawareofoverloading,templateinstantiation,conversionrules—

c++ - 可变参数扩展可以用作逗号运算符调用链吗?

我正在查看“Howtoproperlyusereferenceswithvariadictemplates”,想知道逗号扩展能走多远。这是答案的一个变体:inlinevoidinc(){}templateinlinevoidinc(T&t,Args&...args){++t;inc(args...);}由于可变参数被扩展为以逗号分隔的元素列表,这些逗号在语义上是否等同于模板/函数参数分隔符,或者它们是否被插入词法,使它们适合任何(后处理器)使用,包括逗号运算符?这适用于我的GCC-4.6://Usethesamezero-argument"inc"templateinlinevoidi

c++ - "null logger"- 是否会使用 ostream 运算符的空类从优化代码中编译出什么都不做?

如果我有一个在Release模式下为空的日志记录类,并且有一个什么都不做的ostream运算符。它或多或少看起来像这样:structnull_logger{templateinlinenull_logger&operator我创建了一个简单的测试并将生成的程序集粘贴到下面:constchar*foo(){return"hello";}intmain(){inti=0;null_logger()老实说,我并不完全理解汇编。根据@Als的建议,我寻找了call语句,但没有找到。因此可以安全地假设,在Release模式下,将编译出对该ostream运算符的任何调用吗?这是生成的程序集,使用g

c++ - 在模板类中重载下标运算符

我正在尝试实现一个通用(模板)双向链表,类似于C#.NET实现。我想构建一个“捷径”方法来获取具有特定索引的元素,并决定使用下标运算符。我按照说明做了,想出了这样的东西。templateclassList{public:T&operator[](intindex){returniterator->GetCurrentValue();//iteratorisoftypeIteratorandreturnsT&}};但是当我开始在我的代码中使用它时:List*myList=newList();...intvalue=myList[i];//iisint我收到一个编译器错误:main.cpp

c++ - 如何编写带有自定义标志的 ostream 运算符

我经常想将STL容器写入ostream。以下代码工作正常(至少对于vector和列表):template>classContainer>std::ostream&operatorconst&container){typenameContainer::const_iteratorbeg=container.begin();while(beg!=container.end()){o现在我想扩展此代码以支持可自定义的分隔符。以下方法显然行不通,因为运算符应该只接受两个参数。template>classContainer>std::ostream&operatorconst&container

c++ - 如何正确使用 noexcept 运算符

我已经实现了一个智能指针,它存储一个类型为T的对象,带有调用内部对象方法的代理函数:templateinlineboolcall(Function(T::*function)(Args...)const,Params&&...args)constnoexcept(noexcept(function));但是我发现了一个奇怪的问题——当一个std::exception在一个成员函数中产生时,程序终止了,即使在一个tryblock中调用了代理函数。所以我的问题是:使用noexcept运算符是否正确,如果不是,在这种情况下我应该如何使用它? 最佳答案

c++ - 为什么/什么时候应该使用 C++ 中的作用域运算符在我的类之外声明方法?

我来自.Net背景,我开始学习我在教程中看到的c++here可以通过作用域运算符::在类外部定义函数的内容。这里是教程中给出的例子://classesexample#includeusingnamespacestd;classCRectangle{intx,y;public:voidset_values(int,int);intarea(){return(x*y);}};voidCRectangle::set_values(inta,intb){x=a;y=b;}intmain(){CRectanglerect;rect.set_values(3,4);cout我在谷歌上能找到的都是关

C++运算符重载,我自己的字符串类

我正在尝试在C++11中创建我自己的字符串类,但我遇到了一些问题。将我的类与std::string类进行比较,我不知道如何使用std::string.at(int)='a';方法/重载。我在自己的类中创建了at(int)方法:intat(intindex){if(indexsize-1){throwstd::out_of_range("Error,indexoutofrange");}returndata[index];}如果我只使用它,效果很好:MyString.at(2);在主文件中:MyString="Helloworld!";//Worksfine!MyString.at(2)

c++ - 使用构造函数代替或类型转换运算符

我有以下代码classA{private:intn;public:A(intn):n{n}{}A(constA&a):n{a.n}{}};classB{private:intm;public:B(intn):m{n}{}operatorA()const{returnA(m);}operatorint()const{returnm;}};intmain(int,char**){Bb{1};(A)b;//Failsstatic_cast(b);//Failsb.operatorA();//OK}这失败了callofoverloaded‘A(B&)’isambiguous(gcc,但VC++

c++ - 运算符重载中的 C++ 语法不清晰

我对C++还是个新手,正在尝试理解表达式模板。我在Wikipedia上看到了一个示例代码.我了解大部分程序及其工作原理,但我不清楚编译器如何解释这些行:operatorA&(){returnstatic_cast(*this);}operatorAconst&()const{returnstatic_cast(*this);}来自下面的基本表达式模板类。通常运算符重载的语法是return_datatypeoperator+(args){body}(例如for+operator)但是这会产生错误并且函数中的那些编译没有任何错误。谁能解释一下这两行?运算符之前的A&和Aconst&是做什么